package com.tarena.lbs.coupon.pojo.po;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;

/**
 * 优惠券实体类
 * 对应数据库表: coupon
 */
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
@TableName("coupon")
public class CouponPO implements Serializable {
    /**
     * 优惠券ID
     */
    @TableId
    private Integer id;

    /**
     * 优惠券名称
     */
    private String couponName;

    /**
     * 优惠券类型：1-满减券 2-折扣券 3-现金券 4-免运费券 5-特价券
     */
    private Integer couponType;

    /**
     * 抵扣金额
     */
    private BigDecimal discountValue;

    /**
     * 最大抵扣金额
     */
    private BigDecimal maxDiscountAmount;

    /**
     * 使用范围
     */
    private String applicable;

    /**
     * 最大领取次数
     */
    private Integer usageLimit;

    /**
     * 单次消费限制张数
     */
    private Integer maxUsageLimit;

    /**
     * 开始时间
     */
    private Date startDate;

    /**
     * 截止时间
     */
    private Date endDate;

    /**
     * 优惠券状态：1-未开始 2-进行中 3-已结束
     */
    private Integer status;

    /**
     * 描述
     */
    private String describes;

    /**
     * 商家ID
     */
    private Integer businessId;

    /**
     * 创建时间
     */
    @TableField("create_at")
    private Date createAt;

    /**
     * 更新时间
     */
    @TableField("update_at")
    private Date updateAt;

    /**
     * 领取数量
     */
    private Integer usageNum;

    /**
     * 启用状态：0-禁用 1-启用
     */
    private Integer enableStatus;

    /**
     * 互斥类型
     */
    private Integer exclusionType;

    /**
     * 订单金额
     */
    private BigDecimal orderAmount;
    
    /**
     * 删除状态：0-已删除 1-未删除
     * 注意：在数据库中字段名为coupon_status，所以需要使用@TableField进行映射
     */
    @TableField("coupon_status")
    private Integer couponStatus;
}